home *** CD-ROM | disk | FTP | other *** search
- /*
- * $Id: epson.trm%v 3.50 1993/07/09 05:35:24 woo Exp $
- *
- */
-
- /* GNUPLOT - epson.trm */
- /*
- * Copyright (C) 1990 - 1993
- *
- * Permission to use, copy, and distribute this software and its
- * documentation for any purpose with or without fee is hereby granted,
- * provided that the above copyright notice appear in all copies and
- * that both that copyright notice and this permission notice appear
- * in supporting documentation.
- *
- * Permission to modify the software is granted, but not the right to
- * distribute the modified code. Modifications are to be distributed
- * as patches to released version.
- *
- * This software is provided "as is" without express or implied warranty.
- *
- * This file is included by ../term.c.
- *
- * This terminal driver supports:
- * epson_lx800, nec_cp6, starc,
- * epson_60dpi, tandy_60dpi
- * epson_180dpi
- *
- * AUTHORS
- * Russell Lang
- * William Wilson
- *
- * send your comments or suggestions to (info-gnuplot@dartmouth.edu).
- *
- */
-
- /* The following epson lx800 driver uses generic bit mapped graphics
- routines to build up a bit map in memory. */
- /* by Russell Lang, rjl@monu1.cc.monash.edu.au */
- /* On PC, print using 'copy file /b lpt1:', do NOT use 'print' */
- /* EPSON_init changes outfile to binary mode on PC's */
-
- #ifdef EPSONP
-
- #define EPSONXMAX 512
- #define EPSONYMAX 384
-
- #define EPSONXLAST (EPSONXMAX - 1)
- #define EPSONYLAST (EPSONYMAX - 1)
-
- #define EPSONVCHAR FNT5X9_VCHAR
- #define EPSONHCHAR FNT5X9_HCHAR
- #define EPSONVTIC 6
- #define EPSONHTIC 6
-
- EPSONinit()
- {
- #ifdef REOPEN_BINARY
- reopen_binary();
- #endif
- }
-
-
- EPSONgraphics()
- {
- b_charsize(FNT5X9);
- b_makebitmap((unsigned int)(EPSONXMAX*xsize),
- (unsigned int)(EPSONYMAX*ysize),1);
- }
-
-
- EPSONtext()
- {
- epson_dump();
- b_freebitmap();
- }
-
-
- #define EPSONlinetype b_setlinetype
- #define EPSONmove b_move
- #define EPSONvector b_vector
- #define EPSONput_text b_put_text
- #define EPSON_text_angle b_text_angle
-
- EPSONreset()
- {
- #ifdef vms
- fflush_binary();
- #endif
- }
-
-
- /* output file must be binary mode for epson_dump */
- epson_dump()
- {
- register unsigned int x;
- int j;
- for (j=(b_ysize/8)-1; j>=0; j--) {
- /* select plotter graphics mode (square pixels) */
- fprintf(outfile,"\033J\030"); /* line feed 8/72" = 8 dots */
- fprintf(outfile,"\r\033*\005");
- (void) fputc((char)(b_xsize%256),outfile);
- (void) fputc((char)(b_xsize/256),outfile);
- for (x=0; x<b_xsize; x++) {
- (void) fputc( (char)(*((*b_p)[j]+x)), outfile );
- }
- }
- #ifdef PC
- fprintf(stderr,"Print using: COPY /B\n");
- #endif
- }
-
- #endif /* EPSONP */
-
-
- /* The following NEC CP6 Pinwriter driver uses generic bit mapped graphics
- routines to build up a bit map in memory. */
- /* by Russell Lang, rjl@monu1.cc.monash.edu.au */
- /* On PC, print using 'copy file /b lpt1:', do NOT use 'print' */
- /* NECinit changes outfile to binary mode for PC's */
-
- /* Add a Monochrome NEC printer (for faster speed and line types) jdc */
-
- #ifdef NEC
-
- #define NECXMAX 400
- #define NECYMAX 320
-
- #define NECXLAST (NECXMAX - 1)
- #define NECYLAST (NECYMAX - 1)
-
- #define NECVCHAR FNT5X9_VCHAR
- #define NECHCHAR FNT5X9_HCHAR
- #define NECVTIC 6
- #define NECHTIC 6
-
- /* plane 0=black, 1=cyan(blue), 2=magenta(red), 3=yellow */
- static unsigned int neccolor[] = {1,8,4,2,10,12,6,14};
- static unsigned int necpcolor[]= {0,2,1,4};
-
- static int NECmode;
-
- NECoptions()
- {
- if( END_OF_COMMAND ) {
- strcpy(term_options,"monochrome");
- NECmode='m';
- } else
- if( almost_equals(c_token,"m$onochrome") ) {
- c_token++;
- strcpy(term_options,"monochrome");
- NECmode='m';
- } else
- if( almost_equals(c_token,"c$olor") ) {
- c_token++;
- strcpy(term_options,"color");
- NECmode='c';
- } else
- if( almost_equals(c_token,"d$raft") ) {
- c_token++;
- strcpy(term_options,"draft");
- NECmode='d';
- } else {
- /* error, but since the terminal is already set, default to mono */
- strcpy(term_options,"monochrome");
- NECmode='m';
- int_error("modes: color, monochrome, draft",c_token);
- }
- }
-
- NECinit()
- {
- #ifdef REOPEN_BINARY
- reopen_binary();
- #endif
- }
-
- NECgraphics()
- {
- b_charsize(FNT5X9);
- b_makebitmap((unsigned int)(NECXMAX*xsize),
- (unsigned int)(NECYMAX*ysize),(NECmode=='c' ? 4 : 1));
- }
-
- NECtext()
- {
- if( NECmode=='d' ) {
- nec_draft_dump();
- } else {
- nec_dump();
- }
- b_freebitmap();
- }
-
- NEClinetype(linetype)
- int linetype;
- {
- if( NECmode=='c' ) {
- if (linetype>=6)
- linetype %= 6;
- b_setvalue(neccolor[linetype+2]);
- } else {
- b_setlinetype(linetype);
- }
- }
-
- #define NECmove b_move
- #define NECvector b_vector
- #define NECput_text b_put_text
- #define NEC_text_angle b_text_angle
-
-
- NECreset()
- {
- #ifdef vms
- fflush_binary();
- #endif
- }
-
-
- /* output file must be binary mode for nec_dump */
- nec_dump()
- {
- unsigned int x;
- unsigned int plane,offset;
- int j;
- unsigned int column8;
- unsigned long column24;
- char column3, column2, column1;
- fprintf(outfile,"\033P\033l\005"); /* 10cpi, left margin 5 char */
- for (j=(b_ysize/8)-1;j>=0;j--) {
- fprintf(outfile,"\033J\030"); /* 24/180" line feed */
- for (plane=0; plane<b_planes; plane++) {
- offset=plane*b_psize;
- if (b_planes>1) {
- /* select colour for plane */
- fprintf(outfile,"\033r");
- (void) fputc((char)necpcolor[plane],outfile);
- }
- /* select plotter graphics mode (square pixels) */
- fprintf(outfile,"\r\033*\047");
- (void) fputc((char)((b_xsize*3)%256),outfile);
- (void) fputc((char)((b_xsize*3)/256),outfile);
- for (x=0; x<b_xsize; x++) {
- column8= (unsigned int)(*((*b_p)[j+offset]+x));
- column24=0;
- if (column8&0x01) column24|=(long)0x000007;
- if (column8&0x02) column24|=(long)0x000038;
- if (column8&0x04) column24|=(long)0x0001c0;
- if (column8&0x08) column24|=(long)0x000e00;
- if (column8&0x10) column24|=(long)0x007000;
- if (column8&0x20) column24|=(long)0x038000;
- if (column8&0x40) column24|=(long)0x1c0000;
- if (column8&0x80) column24|=(long)0xe00000;
- column1 = (char) ( column24 & (long)0xff);
- column2 = (char) ((column24>>8) & (long)0xff);
- column3 = (char) ((column24>>16) & (long)0xff);
- (void) fputc(column3,outfile);
- (void) fputc(column2,outfile);
- (void) fputc(column1,outfile);
- (void) fputc(column3,outfile);
- (void) fputc(column2,outfile);
- (void) fputc(column1,outfile);
- (void) fputc(column3,outfile);
- (void) fputc(column2,outfile);
- (void) fputc(column1,outfile);
- }
- }
- }
- fprintf(outfile,"\r\033l");
- (void) fputc('\0',outfile); /* set left margin to 0 */
- if (b_planes > 1) {
- fprintf(outfile,"\033r");
- (void) fputc('\0',outfile); /* set color to black */
- }
- #ifdef PC
- fprintf(stderr,"Print using: COPY /B\n");
- #endif
- #ifdef vms
- fflush_binary();
- #endif
- }
-
- /* output file must be binary mode for nec_dump */
- nec_draft_dump()
- {
- unsigned int x;
- unsigned int plane,offset;
- int j;
- fprintf(outfile,"\033P\033l\005\r"); /* 10cpi, left margin 5 char */
- for (j=(b_ysize/8)-1;j>=0;j--) {
- fprintf(outfile,"\033J\030"); /* 24/180" line feed */
- for (plane=0; plane<b_planes; plane++) {
- offset=plane*b_psize;
- if (b_planes>1) {
- /* select colour for plane */
- fprintf(outfile,"\033r");
- (void) fputc((char)necpcolor[plane],outfile);
- }
- /* select plotter graphics mode (square pixels) */
- fprintf(outfile,"\r\033*");
- (void) fputc('\0',outfile);
- (void) fputc((char)(b_xsize%256),outfile);
- (void) fputc((char)(b_xsize/256),outfile);
- for (x=0; x<b_xsize; x++) {
- (void) fputc( (char)(*((*b_p)[j+offset]+x)), outfile );
- }
- }
- }
- fprintf(outfile,"\r\033l");
- (void) fputc('\0',outfile); /* set left margin to 0 */
- if (b_planes > 1) {
- fprintf(outfile,"\033r");
- (void) fputc('\0',outfile); /* set color to black */
- }
- #ifdef PC
- fprintf(stderr,"Print using: COPY /B\n");
- #endif
- }
-
- #endif /* NEC */
-
- #ifdef STARC
- /* The following Star color driver uses generic bit mapped graphics
- routines to build up a bit map in memory. */
- /* Star Color changes made by William Wilson, wew@naucse.cse.nau.edu */
- /* On PC, print using 'copy file /b lpt1:', do NOT use 'print' */
- /* STARC_init changes outfile to binary mode on PC's */
-
- #define STARCXMAX 512
- #define STARCYMAX 384
-
- #define STARCXLAST (STARCXMAX - 1)
- #define STARCYLAST (STARCYMAX - 1)
-
- #define STARCVCHAR FNT5X9_VCHAR
- #define STARCHCHAR FNT5X9_HCHAR
- #define STARCVTIC 6
- #define STARCHTIC 6
-
- /* plane 0=black, 1=cyan(blue), 2=magenta(red), 3=yellow */
- static unsigned int STARCcolor[] = {1,8,4,2,10,12,6,14};
- static unsigned int STARCpcolor[]= {0,2,1,4};
-
- STARCinit()
- {
- #ifdef REOPEN_BINARY
- reopen_binary();
- #endif
- }
-
-
- STARCgraphics()
- {
- b_charsize(FNT5X9);
- b_makebitmap((unsigned int)(STARCXMAX*xsize),
- (unsigned int)(STARCYMAX*ysize),4);
- }
-
-
- STARCtext()
- {
- STARC_dump();
- b_freebitmap();
- }
-
- STARClinetype(linetype)
- int linetype;
- {
- if (linetype>=6)
- linetype %= 6;
- b_setvalue(STARCcolor[linetype+2]);
- }
-
-
- #define STARCmove b_move
- #define STARCvector b_vector
- #define STARCput_text b_put_text
- #define STARC_text_angle b_text_angle
-
- STARCreset()
- {
- #ifdef vms
- fflush_binary();
- #endif
- }
-
-
- /* output file must be binary mode for STARC_dump */
- STARC_dump()
- {
- unsigned int x;
- unsigned int plane,offset;
- int j;
- for (j=(b_ysize/8)-1;j>=0;j--) {
- fprintf(outfile,"\033J\030"); /* line feed 8/72" = 8 dots */
- for (plane=0; plane<b_planes; plane++) {
- offset=plane*b_psize;
- if (b_planes>1) {
- /* select colour for plane */
- fprintf(outfile,"\033r");
- (void) fputc((char)STARCpcolor[plane],outfile);
- }
- /* select plotter graphics mode (square pixels) */
- fprintf(outfile,"\r\033*\005");
- (void) fputc((char)(b_xsize%256),outfile);
- (void) fputc((char)(b_xsize/256),outfile);
- for (x=0; x<b_xsize; x++) {
- (void) fputc( (char)(*((*b_p)[j+offset]+x)), outfile );
- }
- }
- }
- if (b_planes > 1) {
- fprintf(outfile,"\033r");
- (void) fputc('\0',outfile); /* set color to black */
- }
- #ifdef PC
- fprintf(stderr,"Print using: COPY /B\n");
- #endif
- }
-
- #endif /* STARC */
-
-
- #ifdef EPS180
-
- #define EPSON180VCHAR FNT13X25_VCHAR
- #define EPSON180HCHAR FNT13X25_HCHAR
- #define EPSON180VTIC 18
- #define EPSON180HTIC 18
-
- /* make the total dimensions 8 inches by 6 inches */
- #define EPS180XMAX 1260
- #define EPS180YMAX 1080
-
- #define EPS180XLAST (EPS180XMAX - 1)
- #define EPS180YLAST (EPS180YMAX - 1)
-
- EPS180graphics()
- {
- b_charsize(FNT13X25);
- b_makebitmap((unsigned int)(EPS180XMAX*xsize),
- (unsigned int)(EPS180YMAX*ysize),1);
- }
-
-
- EPS180text()
- {
- eps180_dump();
- b_freebitmap();
- }
-
-
-
- /* output file must be binary mode for eps180_dump */
- eps180_dump()
- {
- register unsigned int x;
- int j;
- fprintf(outfile,"\033@\033+\060\033l\005"); /* reset, set line spacing
- to 24/180", and
- move left margin */
- for (j=(b_ysize/8)-1; j>=0; ) {
- /* select printer graphics mode '39' */
- fprintf(outfile,"\r\n\033*'");
- (void) fputc((char)(b_xsize%256),outfile);
- (void) fputc((char)(b_xsize/256),outfile);
- for (x=0; x<b_xsize; x++) {
- (void) fputc( (char)(*((*b_p)[j]+x)), outfile );
- (void) fputc( (char)(*((*b_p)[j-1]+x)), outfile );
- (void) fputc( (char)(*((*b_p)[j-2]+x)), outfile );
- }
- j -= 3;
- }
- fprintf(outfile,"\r\n\033@\r\n"); /* reset printer */
- #ifdef PC
- fprintf(stderr,"Print using: COPY /B\n");
- #endif
- }
-
- #endif /* EPS180 */
-
- #ifdef EPS60
-
- /* make the total dimensions 8 inches by 5 inches */
- #define EPS60XMAX 480
- #define EPS60YMAX 360
-
- #define EPS60XLAST (EPS60XMAX - 1)
- #define EPS60YLAST (EPS60YMAX - 1)
-
- EPS60graphics()
- {
- b_charsize(FNT5X9);
- b_makebitmap((unsigned int)(EPS60XMAX*xsize),
- (unsigned int)(EPS60YMAX*ysize),1);
- }
-
-
- EPS60text()
- {
- eps60_dump();
- b_freebitmap();
- }
-
-
-
- /* output file must be binary mode for eps60_dump */
- eps60_dump()
- {
- register unsigned int x;
- int j;
- fprintf(outfile,"\033%c\030",'3'); /* set line spacing 24/216" = 8 dots */
- for (j=(b_ysize/8)-1; j>=0; j--) {
- /* select printer graphics mode 'K' */
- fprintf(outfile,"\r\n\033K");
- (void) fputc((char)(b_xsize%256),outfile);
- (void) fputc((char)(b_xsize/256),outfile);
- for (x=0; x<b_xsize; x++) {
- (void) fputc( (char)(*((*b_p)[j]+x)), outfile );
- }
- }
- fprintf(outfile,"\033%c\044\r\n",'3'); /* set line spacing 36/216" = 1/6" */
- #ifdef PC
- fprintf(stderr,"Print using: COPY /B\n");
- #endif
- }
-
- #endif /* EPS60 */
-
- #ifdef TANDY60
-
- /* The only difference between TANDY60 and EPS60 is the inclusion
- of codes to swap the Tandy printer into IBM mode and back
- into Tandy mode. For a Tandy already in IBM mode, use EPS60. */
-
-
- TANDY60text()
- {
- #ifdef PC
- fprintf(stderr, "Inserting Tandy/IBM mode conversion codes\n");
- #endif
- /* Switch to IBM mode, and leave 3 inches above the plot so as
- to get rough vertical centring on the page. Perform the
- centring by setting 1" line feeds and issuing 3 of them. */
- fprintf(outfile, "\033!\033%c%c\n\n\n", '3',216);
- eps60_dump();
- b_freebitmap();
- /* A form feed must be sent before switching back to Tandy mode,
- or else the form setting will be messed up. */
- fprintf(outfile, "\f\033!");
- }
-
-
- #endif /* TANDY60 */
-
- #ifdef OKIDATA
-
- OKIDATAtext()
- {
- okidata_dump();
- b_freebitmap();
- }
-
- int bitrev_tbl[] = {
- 0x00, 0x80, 0x40, 0xc0, 0x20, 0xa0, 0x60, 0xe0,
- 0x10, 0x90, 0x50, 0xd0, 0x30, 0xb0, 0x70, 0xf0,
- 0x08, 0x88, 0x48, 0xc8, 0x28, 0xa8, 0x68, 0xe8,
- 0x18, 0x98, 0x58, 0xd8, 0x38, 0xb8, 0x78, 0xf8,
- 0x04, 0x84, 0x44, 0xc4, 0x24, 0xa4, 0x64, 0xe4,
- 0x14, 0x94, 0x54, 0xd4, 0x34, 0xb4, 0x74, 0xf4,
- 0x0c, 0x8c, 0x4c, 0xcc, 0x2c, 0xac, 0x6c, 0xec,
- 0x1c, 0x9c, 0x5c, 0xdc, 0x3c, 0xbc, 0x7c, 0xfc,
- 0x02, 0x82, 0x42, 0xc2, 0x22, 0xa2, 0x62, 0xe2,
- 0x12, 0x92, 0x52, 0xd2, 0x32, 0xb2, 0x72, 0xf2,
- 0x0a, 0x8a, 0x4a, 0xca, 0x2a, 0xaa, 0x6a, 0xea,
- 0x1a, 0x9a, 0x5a, 0xda, 0x3a, 0xba, 0x7a, 0xfa,
- 0x06, 0x86, 0x46, 0xc6, 0x26, 0xa6, 0x66, 0xe6,
- 0x16, 0x96, 0x56, 0xd6, 0x36, 0xb6, 0x76, 0xf6,
- 0x0e, 0x8e, 0x4e, 0xce, 0x2e, 0xae, 0x6e, 0xee,
- 0x1e, 0x9e, 0x5e, 0xde, 0x3e, 0xbe, 0x7e, 0xfe,
- 0x01, 0x81, 0x41, 0xc1, 0x21, 0xa1, 0x61, 0xe1,
- 0x11, 0x91, 0x51, 0xd1, 0x31, 0xb1, 0x71, 0xf1,
- 0x09, 0x89, 0x49, 0xc9, 0x29, 0xa9, 0x69, 0xe9,
- 0x19, 0x99, 0x59, 0xd9, 0x39, 0xb9, 0x79, 0xf9,
- 0x05, 0x85, 0x45, 0xc5, 0x25, 0xa5, 0x65, 0xe5,
- 0x15, 0x95, 0x55, 0xd5, 0x35, 0xb5, 0x75, 0xf5,
- 0x0d, 0x8d, 0x4d, 0xcd, 0x2d, 0xad, 0x6d, 0xed,
- 0x1d, 0x9d, 0x5d, 0xdd, 0x3d, 0xbd, 0x7d, 0xfd,
- 0x03, 0x83, 0x43, 0xc3, 0x23, 0xa3, 0x63, 0xe3,
- 0x13, 0x93, 0x53, 0xd3, 0x33, 0xb3, 0x73, 0xf3,
- 0x0b, 0x8b, 0x4b, 0xcb, 0x2b, 0xab, 0x6b, 0xeb,
- 0x1b, 0x9b, 0x5b, 0xdb, 0x3b, 0xbb, 0x7b, 0xfb,
- 0x07, 0x87, 0x47, 0xc7, 0x27, 0xa7, 0x67, 0xe7,
- 0x17, 0x97, 0x57, 0xd7, 0x37, 0xb7, 0x77, 0xf7,
- 0x0f, 0x8f, 0x4f, 0xcf, 0x2f, 0xaf, 0x6f, 0xef,
- 0x1f, 0x9f, 0x5f, 0xdf, 0x3f, 0xbf, 0x7f, 0xff
- };
-
- /* output file must be binary mode for okidata_dump */
- okidata_dump()
- {
- register unsigned int x;
- int j;
- char cur_char;
- int prev_char;
-
- prev_char = 0;
- fprintf(outfile,"\033%c%c\020\033*eP:\003",'%','9'); /* set line spacing 16/144" = 8 dots :Turned on single density graphics mode*/
- for (j=(b_ysize/8)-1; j>=0; j--) {
- fprintf(outfile,"\003\016");
- /* (void) fputc((char)(b_xsize%256),outfile); */
- /* (void) fputc((char)(b_xsize/256),outfile); */
- for (x=0; x<b_xsize; x++) {
- if ( (cur_char = (char)
- (bitrev_tbl[ (int) (*((*b_p)[j]+x))])) == '\003') {
- fprintf( outfile, "\003\003");
- }
- else {
- (void) fputc( (char) cur_char , outfile);
- }
- }
- }
- fprintf(outfile,"\003\002\033%c%c\030\r\n",'%','9'); /* Turned off graphics mode: set line spacing 24/144" = 1/6"*/
- #ifdef PC
- fprintf(stderr,"Print using: COPY /B\n");
- #endif
- }
-
- #endif /* OKIDATA */
-
-